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This listing of claims will replace all prior versions, and listings, of claims in tiie application: 



The Status of the Claims 

1. (Original) A metiiod of profiling a tiireaded program during program runtime, 
the method comprising: 

monitoring infomiation exchanged between a processing unit and first and second 
threads executed by the processing unit; 

determining, based on the information exchanged between the processing unit and the 
first and second threads, a critical path of thread execution and maintaining the critical path 
of thread execution in a critical path tree; 

determining, based on the information exchanged between the processing unit and die 
first and second threads, a wait time during which the first thread awaits a synchronization 
event; and 

determining whether the wait time affects the critical path of thread execution. 

2. (Original) A method as defined by claim 1, further comprising indicating that 
the wait time is of a high priority if die wait time affects die critical path of thread execution 
and indicating that the wait time is of a low priority if the wait time does not affect the critical 
path of thread execution. 

3. (Original) A method as defined by claim 1, wherein a leaf is added to the 
critical path tree when the synchronization event is a fork event. 

4. (Original) A method as defined by claim 1, wherein a leaf is added to the 
critical path tree when the synchronization event is a signal event. 

5. (Original) A method as defined by claim 1, wherein a leaf is removed from 
the critical path tree when the synchronization event is a wait event. 

6. (Original) A method as defined by claim 1, wherein a leaf is added to the 
critical path tree when the synchronization event is an entry event. 

7. (Original) A method as defined by claim 1, wherein a leaf is removed from 
the critical path tree when the synchronization event is a block event. 
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8. (Original) A method as defined by claim 1, wherein a leaf is removed from 
the critical path tree when the synchronization event is a suspend event. 

9. (Original) A method as defined by claim 1 , wherein a leaf is added to the 
critical path tree when the synchronization event is a resume event. 

10. (Original) A method as defined by claim 1, further comprising comparing a 
number of active threads to a number of processing resources to determine a utilization 
factor. 

11. (Original) An article of manufacture comprising a machine-accessible 
medium having a plurality of machine-accessible instructions that, when executed, causes a 
machine to: 

monitor information exchanged between a processing unit and first and second 
threads executed by the processing unit; 

determine, based on the information exchanged between the processing unit and the 
first and second threads, a critical path of thread execution and maintaining the critical path 
of thread execution in a critical path tree; 

determine, based on the information exchanged between the processing unit and the 
first and second threads, a wait time during which the first thread awaits a synchronization 
event; and 

determine whether the wait time affects the critical path of thread execution. 

12. (Original) A machine-accessible medium as defined by claim 11, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to indicate that 
the wait time is of a high priority if the wait time affects the critical path of thread execution 
and indicating that the wait time is of a low priority if the wait time does not affect the critical 
path of thread execution. 

13. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a fork event. 

14. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a signal event. 
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15. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a wait event. 

16. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is an entry event. 

17. (Original) A machine-accessible medium as defined by claim 12, wherein the 
pluraUty of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a block event. 

18. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a suspend event. 

19. (Original) A machine-accessible medium as defined by claim 12, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a resume event. 

20. (Cancelled) 

21. (Original) A method of profiling a threaded program during program runtime, 
the method comprising: 

monitoring information exchanged between a processing unit and first and second 
threads executed by the processing unit; 

determining when a cross-thread event has occurred; 

determining, based on the cross-thread event, a critical path of thread execution and 
maintaining the critical path of thread execution in a critical path tree; 

determining, based on the cross-thread event and the information exchanged between 
the processing unit and the first and second threads, a wait time during which the first thread 
awaits a synchronization event; and 

determining whether the wait time affects the critical path of thread execution. 

22. (Original) A method as defined by claim 21, further comprising indicating 
that the wait time is of a high priority if the wait time affects the critical path of thread 
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execution and indicating that the wait time is of a low priority if the wait time does not affect 
the critical path of thread execution.. 

23. (Original) A method as defined by claim 22, wherein the cross-thread event is 
selected from a group consisting of a fork event, an entry event, a signal event, a wait event, a 
suspend event, a resume event, and a block event. 

24. (Original) A method as defined by claim 22, wherein a leaf is added to the 
critical path tree when the synchronization event is a fork event. 

25. (Original) A method as defined by claim 22, wherein a leaf is added to the 
critical path tree when the synchronization event is a signal event. 

26. (Original) A method as defined by claim 22, wherein a leaf is removed from 
the critical path tree when the synchronization event is a wait event. 

27. (Original) A method as defined by claim 22, wherein a leaf is added to the 
critical path tree when the synchronization event is an entry event. 

28. (Original) A method as defined by claim 22, wherein a leaf is removed from 
the critical path tree when the synchronization event is a block event. 

29. (Original) A method as defined by claim 22, wherein a leaf is removed from 
the critical path tree when the synchronization event is a suspend event. 

30. (Original) A method as defined by claim 22, wherein a leaf is added to the 
critical path tree when the synchronization event is a resume event. 

31. (Original) A method as defined by claim 22, further comprising comparing a 
number of active threads to a number of processing resources to determine a utilization 
factor. 

32. (Original) An article of manufacture comprising a machine-accessible 
medium having a plurality of machine-accessible instructions, when executed, causes a 
machine to: 

monitor information exchanged between a processing unit and first and second 
threads executed by the processing unit; 

determine when a cross-thread event has occurred; 
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deteraiine, based on the cross-thread event, a critical path of thread execution and 
maintaining the critical path of thread execution in a critical path tree; 

determine, based on the cross-thread event and the information exchanged between 
the processing unit and the first and second threads, a wait time during which the first thread 
awaits a synchronization event; and 

determine whether the wait time affects the critical path of thread execution. 

33. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to indicate that 
the wait time is of a high priority if the wait time affects the critical path of thread execution 
and indicating that the wait time is of a low priority if the wait time does not affect the critical 
path of thread execution. 

34. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a fork event. 

35. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a signal event. 

36. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a wait event. 

37. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is an entry event. 

38. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a block event. 

39. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to remove a 
leaf from the critical path tree when the synchronization event is a suspend event. 
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40. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to add a leaf to 
the critical path tree when the synchronization event is a resume event. 

41. (Original) A machine-accessible medium as defined by claim 32, wherein the 
plurality of machine-accessible instructions, when executed, causes a machine to compare a 
number of active threads to a number of processing resources to determine a utilization 
factor. 

42. (New) A method as defined in claim 1, wherein the information includes one 
or more timestamps. 
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